草庐IT

Python functools.wraps 等价于类

全部标签

c++ - C# Collection<T> 的 C++ 等价物是什么?如何使用它?

我需要在C++中存储动态创建的某个基本类型的对象的列表/集合/数组(我是C++的新手)。在C#中我会使用泛型集合,我在C++中使用什么?我知道我可以使用数组:SomeBase*_anArrayOfBase=newSomeBase[max];但是我没有得到任何“免费”的东西-换句话说,我不能迭代它,它不会自动扩展等等。那么还有哪些选择呢?谢谢 最佳答案 有std::vector这是一个数组的包装器,但它可以扩展并自动执行。但是,这是一个非常昂贵的操作,所以如果您要进行大量插入或删除操作,请不要使用vector。(可以使用reserve

c++ - 通用等价于 std 函数对象

boost中是否有任何函数对象是std::equal_to、std::greater等函数对象家族的通用等价物?本质上,std::equal_to应该变成类似structgeneric_equal_to{templatebooloperator()(constT&t,constU&u)const{returnt==u;}};我可以看到由于返回类型的问题,std::plus等的通用版本可能会更加棘手(尽管decltype可以解决这个问题)。不过,我看不出std::equal_to函数对象本身需要模板参数的任何可能原因。这些版本肯定存在于boost或STL中的某个地方吗?当然,编写它们很简

c++ - Python 的 zip() 等价于 C 或 C++

这个问题在这里已经有了答案:Sequence-zipfunctionforC++11?(16个答案)关闭9年前。我想使用标准库函数在C++中(如在Python中)压缩两个数组,那么Python的内置函数zip()是否有任何等效项?

python - c++中python "type(<name>, <bases>, <dict>)"的等价物是什么?

好吧,我正在将python3.3嵌入到C++应用程序中。我希望在C++端动态创建一个Python类,就像我在Python中执行以下操作一样:my_type=type("MyType",(object,),dict())我知道我总是可以导入“builtins”模块,但我一般会尽量避免在C++端导入。谢谢! 最佳答案 以下似乎工作得很好:PyObject*type(constchar*name,boost::python::tuplebases,boost::python::dictdict){returnPyType_Type.tp_

c++ - opencl c++ API 包装器中的 clFinish 等价物是什么?

我是opencl的新手,但我对GPU编程并不陌生。我需要确保我的cpu和gpu设备相互同步。看来我应该使用clFinish(cl::commandqueuequeue),但我使用的是openclc++而不是openclc。那么,cl::finish()是否等同于clFinish()还是有类似cl::commandqueue::finish()的东西(哪个VisualStudio无法识别)?您能否举例说明您的答案?我是opencl的新手。 最佳答案 cl::command_queue::finish就是您要找的那个。cl_intfin

c++ - 为什么没有 strand::wrap() 等同于 strand::post()?

strand::wrap()的行为被定义为它创建一个仿函数,该仿函数将在调用时执行strand::dispatch()。我最近在我们的一个执行以下序列的应用程序中遇到了一个错误:my_great_function(...,s.wrap(a),s.wrap(b));应用程序保证s.wrap(a)创建的仿函数在s.wrap(b)之前被调用。但是,存在竞争条件,第一个仿函数在链外调用,因此延迟调用,而第二个仿函数在链内部调用并立即执行。这违反了应用程序的a在b之前的排序假设,并导致未定义的行为。使用strand::post()而不是strand::dispatch()是解决这个问题的一种方法

c++ - 检测 typedef 的等价性

在我的应用程序中,我有一个类型负责(可能)涉及大量数字的计算,还有一个类型用于处理器之间的通信。typedefMyBigIntegerClassbigInt;typedefintsmallInt;通信部分与MyBigIntegerClass不兼容,因此在通信之前,例如bigInts的vector,它必须转换为smallints。到目前为止,完全没有问题。但是,对于大多数问题实例,没有必要使用MyBigIntegerClass。事实上,即使int32_t也足够了。这就是为什么我允许这样的配置typedefint32_tbigInt;typedefint16_tsmallInt;bigIn

C++11/14 : Wrap a function if it exists

我想编写一个wrapper类(非常像一个代理)来聚合一个对象,并将成员函数调用转发给它。在使用可变参数模板和decltype的C++11/14中,这很简单。我的问题是包装对象可能支持也可能不支持某些成员函数。我想出了一个似乎有效的解决方案,但是,它看起来非常笨拙,我正在寻找简化方法。特别是我担心这在编译时可能会非常昂贵(有许多函数要包装)。这种笨拙是因为需要指定函数的返回类型,而无需decltype某些令人窒息的内容。有人有更好的主意吗?下面这段代码也可用live.#include#include///Computetheresulttypeofamemberfunctioncall,

c# - C# 或 VB.NET 中的 std::bind 等价物

我正在将“同步”代码(即使用Windows事件等待其他线程完成某事)重构为“异步”代码(使用委托(delegate)来实现回调机制)。在同步代码中,我有时会有等待结束后需要使用的局部变量。当这样的代码变为异步时,这些局部变量就会丢失(回调处理程序无法访问它们)。我可以将它们存储为类属性,但感觉很浪费。在C++中,我使用std::bind来解决这个问题。我只是将与回调处理程序所需的局部变量一样多的参数添加到回调处理程序中,并在调用异步方法时绑定(bind)它们。例如,假设异步方法回调接收类型为CallbackParam的对象,调用者使用类型为LocalA和LocalB的两个局部变量。vo

c++ - C++ 中的 Matlab griddata 等价物

我正在寻找与Matlab的griddata函数或任何2D全局插值方法等效的C++。我有一个使用Eigen3的C++代码。我将有一个包含x、y和z值的EigenVector,以及两个等效于Meshgrid在Matlab中生成的Eigen矩阵。我想将Vectors的z值插值到由Meshgrid等价物定义的网格点上(这将稍微超出原始点的外部,因此需要进行较小的外推)。我不太在意准确性——它不需要完美。但是,我不能接受NaN作为解决方案——无论数据间隙如何,都必须在网格上的所有位置计算插值。换句话说,留在凸包内不是一种选择。我不想从头开始编写插值,但如果有人想向我指出非常好的(和明确的)配方,